<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>预解析</title>
  </head>
  <body>
    <script>
      // 坑 1
      console.log(num); // 输出 undefined
      var num = 10;
      // 以上两句代码相当于执行了以下代码
      // var num;
      // console.log(num);
      // num = 10;

      // 当 function 声明函数时，函数先调用和后调用都是一样的，因为有 函数提升
      fn();
      function fn() {
        console.log(123);
      }
      // 以上代码相当于执行了以下代码(因为函数提升)
      // function fn() {
      //   console.log(123);
      // }
      // fn();

      // 坑 2
      fun(); // 报错：fun is not a function
      var fun = function () {
        console.log(222);
      };
      // 以上代码相当于执行了以下代码(此时会有变量提升，所以当用函数表达式声明函数时，函数调用一定要在声明后面)
      // var fun;
      // fun();
      // fun = function () {
      //   console.log(222);
      // };
    </script>
  </body>
</html>
